let layer = layui.layer;

// 裁剪头像
// 1.1 获取裁剪区域的 DOM 元素
let $image = $("#image");

// 1.2 配置选项
const options = {
  // 纵横比
  aspectRatio: 1,
  // 指定预览区域
  preview: ".img-preview",
};

// 1.3 创建裁剪区域
$image.cropper(options);

// 点击选择图片触发事件
$("#layui-btn").on("click", function () {
  $("#files_img").click();
});

$("#files_img").on("change", function (e) {
  let filelist = e.target.files;
  if (filelist.legth === 0) return layui.msg("请选择图片");
  let file = e.target.files[0];
  let imgURL = URL.createObjectURL(file);
  $("#image")
    .cropper("destroy") // 销毁旧的裁剪区域
    .attr("src", imgURL) // 重新设置图片路径
    .cropper(options); // 重新初始化裁剪区域
});

$("#btnuplod").on("click", function () {
  let dataURL = $image
    .cropper("getCroppedCanvas", {
      // 创建一个 Canvas 画布
      width: 100,
      height: 100,
    })
    .toDataURL("image/png");
  $.ajax({
    type: "POST",
    url: "/my/update/avatar",
    data: { avatar: dataURL },
    success: (res) => {
      if (res.status !== 0) return layer.msg(res.message);
      layer.msg(res.message);
      window.parent.getUserInfo();
    },
  });
});
